草庐IT

c++ - std::async 超时

全部标签

c - 从 Golang 中的 c 函数返回字符串

我正在尝试在GO中调用C函数。这适用于某些扩展(对于整数)。但是,存在问题下面给出了一个最小的例子packagemain/*#include#include#includevoidmy_reverse(char*src,intlen,char*dst){dst=malloc(sizeof(char)*(len+1));printf("[c-part]src=%s\n",src);for(inti=0;i这是两个c函数,它们在c中分配一个新的缓冲区。但是,我得到了输出[c-part]src=HelloWorld[c-part]dst=dlroWolleH[gopart]dst=willr

c - 找不到gmp库

我试着安装依赖gmp的pbc库。Dockerfile:FROMgolang:1.9.6-alpine3.7RUNmkdir-p/go/src/appWORKDIR/go/src/appCOPY./go/src/appRUNapkadd--updategitgccbuild-baseflexbisongmpRUNwgethttps://crypto.stanford.edu/pbc/files/pbc-0.5.14.tar.gz&&\tar-xvfpbc-0.5.14.tar.gz&&\cdpbc-0.5.14&&\./configure--prefix=$HOME/.local&&\m

c# - 您将如何使用 Scala 的异步使多个异步请求超时?

我不了解Scala,但我很好奇它的异步功能(类似于C#的)。您将如何将此go代码转换为Scalaasync?http://talks.golang.org/2012/concurrency.slide#47c:=make(chanResult)gofunc(){c 最佳答案 这是如何完成的草图(未经测试;我不声称这是最佳解决方案)://IassumethattheWeb/Image/VideofunctionsreturninstancesofFuture[Result]valf1=Web(query)valf2=Image(que

当用户在 3 分钟内未向 Go Web 服务器发送数据时,Go session 超时

我将使用Go构建Web服务器。现在我想将sessionID返回给用户使用用户名和密码登录。而且我认为我可以接受登录程序。用户每次要发布数据时都会使用sessionID。但是,用户登录后,如果用户在3分钟内没有发送数据,我会尝试销毁session,使sessionid不再有效。那么,当用户在3分钟内未发布数据时,如何使session过期。(我将使用beego,beego有session超时,但它确实提到它会超时取决于发布数据间隔)谢谢。 最佳答案 您可以设置上次使用session的时间。假设cookie存储创建为Store:=sess

c - 添加文件到/usr/local/include

我最近在一台linux机器上安装了openjtalk,我希望能够用Go包装它。openjtalk的源文件有几个不同来源的子文件夹,我假设是编译器找到的,因为有make文件。我应该将每个子文件夹复制到/usr/local/include中吗?这是修复包含依赖项的“正确”方法吗?根据我的测试,如果我复制包含的文件,Go似乎可以找到它们,但我不确定这是否是正确的linux做事方式。 最佳答案 更改外部库的位置通常不是一个好主意。有些库会自动将自己放入编译器的包含路径中,但对于那些不这样做的库,将它们的路径添加到编译器的包含路径中总是一个更

c - 如何将 char * 更改为等效的 Go

我有一些看起来像这样的C代码-*((Oid*)((char*)(tup)其中Oid是一个uint32类型,tup是一个结构。我想把它转换成golang。我已经解码了结构,但无法弄清楚如何将上面的行转换为golang。 最佳答案 Go等价于转换C指针是将指针转换为unsafe.Pointer,然后可以将其转换为您希望的任何类型的指针。如果tup是指向C中结构的指针,您可以将它转换为*uint32,如下所示:u:=(*uint32)(unsafe.Pointer(C.tup)) 关于c-如何

去超时不开火

为了好玩,我在Go中实现了一些排序算法,现在我想测试它们对随机整数的性能。所以我写了下面的程序。我遵循了类似的格式:https://gobyexample.com/timeouts但是,似乎超时未正确触发。下面是我的代码:packagemainimport("allanpinkerton.com/algorithms/sorting""fmt""math/rand""os""strconv""time")//PrintsoutthetimeelapsedsincestartfunctimeExecution(startTimetime.Time,functionNamestring,i

google-app-engine - 在达到 30 秒限制之前抛出 AppEngine 数据存储区超时错误

使用AppEngineGo,从40k实体顺序的表中读取时,我一直看到此错误:API错误5(datastore_v3:TIMEOUT):数据存储操作超时,或数据暂时不可用。这是在查询触发后的400毫秒内发生的。除了达到挂钟的限制之外,是否还有其他原因可能导致此错误?谢谢! 最佳答案 事实证明,每个单独的API调用都有5秒的超时。如果您需要更多时间,您可以像这样包装您的上下文:ctx:=appengine.Timeout(appengine.NewContext(req),30*time.Second)

go - 从 golang 或 core.async 中的输出 channel 批处理项目

我有一个将数据从kafka索引到elasticsearch的用例。Elasticsearch有一个批量API,它将多条消息捆绑在一个API调用中以进行索引。这比对每条消息逐条索引要高效得多。我正在使用Clojure来执行此操作。自然地,我想使用core.async,使用来自kafka的消息并输入到channel中,缓冲一段时间或当channel有足够的消息时,然后在一个elasticsearch批量API调用中为它们建立索引。问题是只要有一条消息传入,channel的输出就会发出信号。一个简单的解决方案是在阻塞队列中缓冲来自channel输出的传入消息,但这听起来似乎违背了使用chan

c - 不在 cgo 中显示 printf 结果

当我运行这段代码时,我希望打印出类似A:4,B:89的结果。但实际上,不显示任何内容。为什么这个程序不将结果显示到标准输出?main.go:packagemain/*#include"c.h"*/import"C"import("unsafe")typeSstruct{AintBint}funcmain(){s:=&S{A:4,B:89}pass_to_c:=(*C.S)(unsafe.Pointer(s))C.gostruct(pass_to_c)}c.h#include#includetypedefstruct{longintA;longintB;}S;externvoidgost